Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
mem-fs-editor
Advanced tools
The mem-fs-editor package is a utility for working with the file system in memory. It provides a way to perform file operations such as reading, writing, and modifying files without directly interacting with the disk until you decide to commit the changes. This is particularly useful for scaffolding tools and generators.
Reading Files
This feature allows you to read the content of a file from the file system into memory. The code sample demonstrates how to read a file using mem-fs-editor.
const memFs = require('mem-fs');
const editor = require('mem-fs-editor');
const store = memFs.create();
const fs = editor.create(store);
const content = fs.read('path/to/file.txt');
console.log(content);
Writing Files
This feature allows you to write content to a file in memory and then commit the changes to the disk. The code sample demonstrates how to write to a file and commit the changes.
const memFs = require('mem-fs');
const editor = require('mem-fs-editor');
const store = memFs.create();
const fs = editor.create(store);
fs.write('path/to/file.txt', 'Hello, World!');
fs.commit(() => {
console.log('File written to disk');
});
Modifying Files
This feature allows you to modify files in memory, such as copying or moving files. The code sample demonstrates how to copy a file from one location to another and commit the changes.
const memFs = require('mem-fs');
const editor = require('mem-fs-editor');
const store = memFs.create();
const fs = editor.create(store);
fs.copy('path/to/source.txt', 'path/to/destination.txt');
fs.commit(() => {
console.log('File copied');
});
fs-extra is a package that extends the native Node.js fs module with additional methods for working with the file system. It provides similar functionalities such as reading, writing, and copying files, but it operates directly on the disk rather than in memory. This makes it less suitable for scenarios where you want to batch file operations before committing them.
vinyl-fs is a file system utility for working with streams in Gulp. It allows you to read, write, and modify files using a stream-based approach. While it provides similar functionalities to mem-fs-editor, it is more focused on stream processing and is commonly used in build systems.
graceful-fs is a drop-in replacement for the native fs module that improves handling of file system operations, especially in environments with high concurrency. It provides similar file operation methods but focuses on enhancing the reliability and performance of file system interactions.
File edition helpers working on top of mem-fs
var memFs = require("mem-fs");
var editor = require("mem-fs-editor");
var store = memFs.create();
var fs = editor.create(store);
fs.write("somefile.js", "var a = 1;");
#read(filepath, [options])
Read a file and return its contents as a string.
You can alternatively get the raw contents buffer if you pass options.raw = true
.
By default, calling read()
on a file path that does not exist throws error. You can, however, pass options.defaults = 'your default content'
to get a default content you pass in, if you prefer to not deal with try/catch.
#readJSON(filepath, [defaults])
Read a file and parse its contents as JSON.
readJSON()
internally calls read()
but will not throw an error if the file path you pass in does not exist. If you pass in an optional defaults
, the defaults
content will be returned in case of the target file is missing, instead of undefined
. (Error would still be thrown if JSON.parse
failed to parse your target file.)
#write(filepath, contents)
Replace the content of a file (existing or new) with a string or a buffer.
#writeJSON(filepath, contents[, replacer [, space]])
Replace the content of a file (existing or new) with an object that is to be converted by calling JSON.stringify()
.
contents
should usually be a JSON object, but it can technically be anything that is acceptable by JSON.stringify.
Optionally pass replacer
and space
as the last two arguments, as defined by JSON.stringify. spacer
is used to format the output string (prettify).
Default value for space
is 2
, when not specified.
#append(filepath, contents, [options])
Append the new contents to the current file contents.
options.trimEnd
(default true
). Trim trailing whitespace of the current file contents.options.separator
(default os.EOL
). Separator to insert between current and new contents.#extendJSON(filepath, contents[, replacer [, space]])
Extend the content of an existing JSON file with the partial objects provided as argument.
Optionally take the same JSON formatting arguments than #writeJSON()
.
#delete(filepath, [options])
Delete a file or a directory.
filePath
can also be a glob
. If filePath
is glob, you can optionally pass in an options.globOptions
object to change its pattern matching behavior. The full list of options are being described here. The sync
flag is forced to be true
in globOptions
.
#copy(from, to, [options], context[, templateOptions ])
Copy a file from the from
path to the to
path.
Optionally, pass an options.process
function (process(contents)
) returning a string or a buffer who'll become the new file content. The process function will take a single contents argument who is the copied file contents as a Buffer
.
option.ignoreNoMatch
can be used to silence the error thrown if no files match the from
pattern.
from
can be a glob pattern that'll be match against the file system. If that's the case, then to
must be an output directory. For a globified from
, you can optionally pass in an options.globOptions
object to change its pattern matching behavior. The full list of options are being described here. The nodir
flag is forced to be true
in globOptions
to ensure a vinyl object representing each matching directory is marked as deleted
in the mem-fs
store.
#copyTpl(from, to, context[, templateOptions [, copyOptions]])
Copy the from
file and, if it is not a binary file, parse its content as an ejs template where context
is the template context (the variable names available inside the template).
You can optionally pass a templateOptions
object. mem-fs-editor
automatically setup the filename option so you can easily use partials.
You can also optionally pass a copyOptions
object (see copy() documentation for more details).
Templates syntax looks like this:
<%= value %>
<%- include('partial.ejs', { name: 'Simon' }) %>
Dir syntax looks like this:
/some/path/dir<%= value %>/...
Refer to the ejs documentation for more details.
#move(from, to, [options])
Move/rename a file from the from
path to the to
path.
#move
internally uses #copy
and #delete
, so from
can be a glob pattern, and you can provide options.globOptions
with it.
#exists(filepath)
Returns true
if a file exists. Returns false
if the file is not found or deleted.
#commit([filters,] callback)
Persist every changes made to files in the mem-fs store to disk.
If provided, filters
is an array of TransformStream to be applied on a stream of vinyl files (like gulp plugins).
callback
is called once the files are updated on disk.
FAQs
File edition helpers working on top of mem-fs
The npm package mem-fs-editor receives a total of 1,018,649 weekly downloads. As such, mem-fs-editor popularity was classified as popular.
We found that mem-fs-editor demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.